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AMENDMENTS TO THE CLAIMS 

1. (Currently amended) A method for processing a host commemd in a storage system 
including a plurality of storage elements coupled to a plurality of storage controllers, 
the method comprising the steps of: 

at a first one of said plurality of storage controllers, 

receiving a host command directed to a volume of said storage system from a 
host; 

determining a target storage element of said storage system corresponding to 
said volume; 

determining a target storage controller from said plurality of storage controllers 
corresponding to said target storage element; 

if said target storage controller is not said first one of said plurality of storage 
controllers, forwarding the host command to said target storage controller; 

at the target storage controller, 

receiving the host command forwarded by the first one of said plurality of 
controllers; 

executing said host command; 

forwarding, to said first one of said plurality of storage controllers, an execution 
status associated with said host command; and 

at said first one of said plurality of storage controllers. 
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receiving said execution status; and 

forwarding said execution status to said host^ 

wherein said step of determining a target storage controller comprises searching a 
mapping table . 

2. (Canceled) 

3. (Currently amended) The method o f claim 2 claim 1. further comprising the step of: 

before receiving a host command at said first one of said plurality of storage controllers, 
creating said mapping table to reflect a mapping between volumes and controllers of 
said storage system. 

4. (Currently amended) A method for processing a host command in a storage system 
including a plurality of storage elements coupled to a plurality of storage controllers, 
the method comprising the steps of: 

at a first one of said plurality of storage controllers, 

receiving a host command directed to a virtual volume of said storage system 
from a host; 

determining a plurality of logical volumes of said storage system corresponding 
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to said virtual volume; 

determining a plurality of target storage controllers from said plurality of storage 
controllers corresponding to said plurality of logical volumes; 

sending a component command to each of said plurality of target storage 
controllers, the component command for a particular one of said plurality of 
target storage controllers corresponding to at least a portion of the host 
command and relating to the logical volume associated with the particular target 
controller; 

at each of said plurality of the target storage controllers, 

receiving the component command sent by the first one of said plurality of 
controllers; 

executing said component command; 

forwarding, to the first one of said plurality of storage controller, an execution 
status; and 

at said first one of said plurality of storage controllers, 

receiving said execution status from each one of said plurality of target storage 
controllers; 

determining an aggregate host command execution status from said received 
execution status; and 

forwarding said aggregate host command status to said host^ 
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wherein said step of determining a plurality of target storage controllers comprises 
searching a mapping table . 

5. (Canceled) 

6. (Currently amended) The method o f claim 5 claim 4. further comprising the step of: 

before receiving a host command at said first one of said plurality of storage controllers, 
creating said mapping table to reflect a mapping between virtual volumes and logical 
volumes of said storage system. 

7. (Currently amended) A storage system, comprising: 

a plurality of storage controllers, each one of said plurality of storage controllers 
comprising: 

at least one host port for communicating with a plurality of hosts; and 

at least one storage element port for communicating with a plurality of storage 
elements; 

an interconnect connected to each of said plurality of storage controllers;-arvd: 

at least one storage element, each storage element being coupled to a respective storage 
element port: and 
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a configuration controller for setting up mappings between storage volumes and 
storage elements. 

wherein said plurality of storage controllers further comprise means for processing a 
host command received on any host port targeted to a storage volume on any one of 
said plurality of storage elements and means for searching said mappings . 



8. (Canceled) 



9. (Currently amended) A storage system, comprising: 

a plurality of storage controllers, each one of said plurality of storage controllers 
comprising: 

at least one host port for communicating with a plurality of hosts; and 

at least one storage element ports for communicating with a plurality of storage 
elements; 

an interconnect cormected to each of said plurality of storage controllers;-aFtd 

at least one storage element, each storage element being coupled to a respective storage 
element port; and 

a configuration controller for setting up mappings between virtual volumes and logical 
volumes. 
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wherein said plurality of storage controllers further comprise means for processing a 
host command received on any host port targeted to a virtual volume on said plurality 
of storage elements and means for searching said mappings . 



10. (Canceled) 



11. (Currently amended) A scalable storage controller, comprising: 
a high speed intercormect; 

a plurality of modules, each of said plurality of modules comprising: 
a cache memory; 

an intercormect port, coupled to said high speed interconnect; 
a storage port, for coupling to a storage device; 
a host port, for coupling to a host; and 

a processing element, coupled to said cache memory, said interconnect port, said 
storage port, and said host port^ 

wherein the processing element of each of said modules are configured to search 
mappings between storage volumes and storage devices . 
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12. (Original) The scalable storage controller of claim 11, wherein said high speed 
interconnect is a serial interconnect. 

13. (Original) The scalable storage controller of claim 11, wherein said high speed 
interconnect is a fibre charmel loop. 

14. (Original) The scalable storage controller of claim 11, wherein said high speed 
interconnect is a switched serial network. 

15. (Currently amended) A scalable storage controller, comprising: 
a primary interconnect; and 

a plurality of modules, each of said plurality of modules comprising: 
a cache memory; 

an interconnect port, coupled to said primary fibre channel interconnect; 
a storage port, for coupling to a storage device; 
a host port, for coupling to a host; and 

a processing element, coupled to said cache memory, said interconnect port, said 
storage port, and said host port; 



DSMDB-2094531v01 



8 



Application No. 10/822,793 Docket No.: A7995.0014 

Reply to Office Action of May 2, 2006 

wherein the processing element of each of said modules are configured to process a host 
command for accessing a virtual volume by causing each module associated with said 
virtual volume to access its respective storage devic e and are configured to search 
mappings between virtual volumes and logical volumes . 

16. (Original) The scalable storage controller of claim 15, further comprising: 
a redundant interconnect; 

wherein each of said modules further comprises another interconnect port coupled to 
said redundant interconnect. 



17. (Currently amended) In a storage controller comprising a plurality of modules each 
capable of receiving host commands, a method of conflict detection, comprising: 

receiving, at a first module, a first access request; 

receiving, at a second module, a second access request; 

at each of said first and second modules, 

determining whether said received access reques t requires coordination 
corresponds to either a read or a write request to two or more storage elements: 

if said received access request is determined to roquiro coordinatio n correspond 
to either a read or a write request to two or more storage elements, executing a 
coordination request, and 
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if said coordination request is not granted, 

indicating in a conflict table that said received access request 
is in conflict; and 

holding said access request; 

if said coordination request is granted, 

executing said received access request; 

searching said conflict table to find an entry in conflict with 
said received access request; 

if said search is successful, notifying the module associated 
with said found entry; and 

if said search is unsuccessful, releasing said coordination 
request. 

18. (Original) The method of claim 17, wherein said step of executing a coordination 
request comprises: 

searching a coordination data structure to find a data structure having an address range 
encompassing an address range associated said received access request; 

if the data structure is found, attempting to reserve said data structure; 

if said attempt to reserve is not successful, 
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indicating the said coordination request is not granted; 
if said attempt to reserve is successful, 

indicating that said coordination request is granted; 
if said data structure is not found, 

allocating said data structure and indicating said coordination request is 

granted. 
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